app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
LAST -> APP2(app2(compose, hd), reverse)
LAST -> APP2(compose, hd)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(cons, x), l)
INIT -> APP2(app2(compose, tl), reverse)
INIT -> APP2(compose, tl)
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(reverse2, xs)
INIT -> APP2(compose, reverse)
APP2(reverse, l) -> APP2(reverse2, l)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(reverse, l) -> APP2(app2(reverse2, l), nil)
INIT -> APP2(app2(compose, reverse), app2(app2(compose, tl), reverse))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
LAST -> APP2(app2(compose, hd), reverse)
LAST -> APP2(compose, hd)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(cons, x), l)
INIT -> APP2(app2(compose, tl), reverse)
INIT -> APP2(compose, tl)
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(reverse2, xs)
INIT -> APP2(compose, reverse)
APP2(reverse, l) -> APP2(reverse2, l)
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(reverse, l) -> APP2(app2(reverse2, l), nil)
INIT -> APP2(app2(compose, reverse), app2(app2(compose, tl), reverse))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP2(app2(reverse2, app2(app2(cons, x), xs)), l) -> APP2(app2(reverse2, xs), app2(app2(cons, x), l))
POL( reverse2 ) = 0
POL( APP2(x1, x2) ) = x1
POL( app2(x1, x2) ) = x2 + 1
POL( cons ) = max{0, -1}
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP2(app2(app2(compose, f), g), x) -> APP2(g, app2(f, x))
APP2(app2(app2(compose, f), g), x) -> APP2(f, x)
POL( hd ) = max{0, -1}
POL( app2(x1, x2) ) = x1 + x2 + 1
POL( compose ) = 1
POL( tl ) = 1
POL( reverse2 ) = max{0, -1}
POL( APP2(x1, x2) ) = max{0, x1 - 1}
POL( nil ) = max{0, -1}
POL( cons ) = 1
POL( reverse ) = 1
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
app2(app2(app2(compose, f), g), x) -> app2(g, app2(f, x))
app2(reverse, l) -> app2(app2(reverse2, l), nil)
app2(app2(reverse2, nil), l) -> l
app2(app2(reverse2, app2(app2(cons, x), xs)), l) -> app2(app2(reverse2, xs), app2(app2(cons, x), l))
app2(hd, app2(app2(cons, x), xs)) -> x
app2(tl, app2(app2(cons, x), xs)) -> xs
last -> app2(app2(compose, hd), reverse)
init -> app2(app2(compose, reverse), app2(app2(compose, tl), reverse))